跳到主要内容

MySQL 面试题

1、MySQL 中有哪几种锁?

1、 表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低;

2、 行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高;

3、 页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并;发度一般。

2、MySQL 中有哪些不同的表格?

共有5 种类型的表格:

1、MyISAM

2、Heap

3、Merge

4、INNODB

5、MISAM

3、简述在MySQL 数据库中 MyISAM 和InnoDB 的区别

MyISAM: 不支持事务, 但是每次查询都是原子的; 支持表级锁, 即每次操作是对整个表加锁; 存储表的总行数;

一个MYISAM 表有三个文件: 索引文件、表结构文件、数据文件;采用菲聚集索引, 索引文件的数据域存储指向数据文件的指针。辅索引与主索引基本一致, 但是辅索引不用保证唯一性。**InnoDb:**支持ACID 的事务, 支持事务的四种隔离级别; 支持行级锁及外键约束: 因此可以支持写并发; 不存储总行数:一个InnoDb 引擎存储在一个文件空间( 共享表空间, 表大小不受操作系统控制,一个表可能分布在多个文件里), 也有可能为多个( 设置为独立表空, 表大小受操作系统文件大小限制,一般为 2G), 受操作系统文件大小的限制;主键索引采用聚集索引( 索引的数据域存储数据文件本身), 辅索引的数据域存储主键的值; 因此从辅索引查找数据, 需要先通过辅索引找到主键值, 再访问辅索引; 最好使用自增主键, 防止插入数据时,为维持 B+树结构, 文件的大调整。

4、MySQL 中InnoDB 支持的四种事务隔离级别名称,以及逐级之间的区别?

SQL标准定义的四个隔离级别为:

1、 readuncommited:读到未提交数据;

2、 readcommitted:脏读,不可重复读;

3、 repeatableread:可重读;

4、 serializable:串行事物;

5、CHAR 和VARCHAR 的区别?

1、 CHAR和VARCHAR类型在存储和检索方面有所不同;

2、 CHAR列长度固定为创建表时声明的长度,长度值范围是1到255当CHAR值被存储时,它们被;用空格填充到特定长度, 检索 CHAR 值时需删除尾随空格。